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(57) A method and apparatus for matching com- 
pressed video signals to a communications channel. 
The compressed bitstream is partially decompressed 
and the bitstream is regenerated with a reduced bit rate 
to match the channel capacity. Specifically, control in- 
formation is decoded and entropy decoding is per- 
formed on the entropy coded, quantized frequency do- 
main data. Then, the quantized frequency domain data 
is re-quantized and re-entropy coded so that the result- 
ing compressed bitstream does not exceed the channel 



capacity bit rate However, this entire rate conversion 
process is performed without converting the frequency 
domain data out of the frequency domain (and back 
again) as is done by prior art techniques. That is, the 
frequency domain data is not inverse transformed (out 
of the frequency domain) in the process of re-quantiza- 
tion. In this manner, a compressed and stored video sig- 
nal can be matched to the constraints of a given com- 
munications channel with substantially less computa- 
tional cost than is required by the techniques of the prior 
art. 
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Description 

Field of the Invention 

s The present invention relates generally to the field of video signal coding and more particularly to the problem ot 

matching the level of compression of coded video signals to the requirements of a given communications channel. 

Background of the Invention 

'0 Over the past several years, video signal coding technology has progressed to the point where substantial com- 

pression factors can be obtained with little or no bss of video signal quality. In addition, with the advent of high capacity 
affordable digital storage media, it has become practical to store large quantities of digital video data (representing 
video programs such as movies, for example) in such a compressed form. These compressed and stored video pro- 
grams may then subsequently be transmitted over a communications channel to a requesting customer location and 

is decoded (i.e., uncompressed) thereat. Among other applications, this technology may be used to enable a customer 
to receive a selected video program at a customer-requested time. Such applications, commonly known as Video-on- 
Demand services, are expected to become quite commonplace in the near future. In fact, the market for such services 
is expected by some observers to approach levels comparable to that of today's huge video rental market. 

Meanwhile, of course, the available bandwidth of the various communications channels -that might be used for 

20 such services is not unlimited. Moreover, the characteristics of the channel (e.g., the available bandwidth) are not likely 
to be known when the original video program is compressed (Le., encoded), or they may change between the time the 
video program is encoded and the time it is desired that the program be transmitted. Thus, even given the substantial 
compression factors which may be achieved without sacrificing video quality, it may not always be the case that sufficient 
channel capacity exists to transmit any given requested video program across the appropriate communications channel 

25 at the time of the request. 

One approach to solving the problem of bandwidth limitations is to compromise the divergent goals of maximum 
video quality and minimum use of channel bandwidth by storing a video signal having less than a perceptually perfect 
quality. That is, a video program may be compressed by a factor which is larger than those which do not impact the 
quality of the video signal. Even though there may be some reduction in the quality of the resultant video, the quality 

30 level may still be sufficient so as not to be noticeable (or at least be acceptable) to most viewers. Unfortunately, this 
approach makes the higher quality video unavailable even when sufficient channel bandwidth is available, and, more- 
over, will not allow for the transmission of the video program at all when the available bandwidth is very limited. 

Another possible solution is to store multiple copies of each video program. Each copy could be encoded at a 
different bit rate - that is, with a different compression factor. (Typically, the compression factor is varied by varying 

35 the step size of the data quantizer - a larger quantization step size results in a correspondingly larger compression 
factor.) When a request to transmit the video program is received, the version that has a bit rate less than (but closest 
to) the available channel capacity is selected and transmitted. This solutbn provides high quality video when the nec- 
essary channel capacity is available, and provides low quality video when it is not. However, this approach has the 
drawback that it requires the storage of multiple copies of every video program. When there are many thousands of 

40 video programs (e.g., movies) to be stored, this approach can become quite uneconomic il not totally impractical. 

A better solution is to store a single high quality version of the video program, and then to reduce the bit rate as 
needed at the time of transmission. When the transmission channel has sufficient capacity (Le., "a capacity greater 
than or equal to the bit rate of the stored video program), the requesting customer would get the high quality video 
program which has been stored directly transmitted to his or her location for decoding thereat. If, on the other hand, 

45 the channel capacity is insufficient (i.e., less than the bit rate of the stored video program), some means of reducing 
the bit rate to match the available channel capacity could be provided in real time. In such a case, of course, the 
requesting customer may receive a video of less than perceptually perfect quality. However, in this manner, a single 
stored copy of the video program could feed communications channels having varying capacities. 

One approach to performing such a bit rate reduction on an already coded video signal consists of decoding the 

so stored video program to reconstruct the original video data, and then to re-encode this data to a bit rate which matches 
the channel capacity. However, for many codecs {coder/decoder systems), the encoder complexity can be several 
orders of magnitude larger than the complexity of the decoder. Such a complexity asymmetry makes economic sense 
in many applications where a decoder must be included at each customer location (e.g., in each television set), whereas 
an encoder must only be provided at the video program source. For example, the well known video coding standards 

ss adopted by the Motion Picture Experts Group -- MPEG-I and MPEG-II - use motion compensated, discrete cosine 
transform based systems for which the encoders are far more complex than the decoders. Consequently, however, 
the technique of decoding the stored video and then re-encoding the result with a conventional encoder suffers from 
a degree of computational complexity which can adversely impact a Video-on-Demand service both economically and 
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in terms of performance. 
Summary of the Invention 

5 in accordance with an illustrative embodiment of the present invention, a method and apparatus for matching 

compressed video signals to a communications channel is provided. The compressed bitstream is partially decom- 
pressed and the bitstream is regenerated with a reduced bit rate to match the channel capacity. Specifically, control 
information is decoded and entropy decoding is performed on the entropy coded : quantized frequency domain data. 
Then, the quantized frequency domain data is re-quantized and re-entropy coded so that the resulting compressed 

10 bitstream does not exceed the channel capacity bit rate. However, this entire rate conversion process is performed 
without converting the frequency domain data out of the frequency domain (and back again) as is done by prior art 
techniques. That is, the frequency domain data is not inverse transformed (out of the frequency domain) in the process 
of re-quantization. In this manner, a compressed and stored video signal can be matched to the constraints of a given 
communications channel with substantially less computational cost than is required by the techniques of the prior art. 

15 

Brief Description of the Drawings 

Fig. 1 shows an environment in which a compressed video signal may be matched to a communications channel 
in accordance with an illustrative embodiment of the present invention. 
20 Fig. 2 shows an illustrative video encoder which may be used in the environment of Fig. 1. 

Fig. 3 shows an illustrative video decoder which may be used in the environment of Fig. 1. 
Fig, 4 shows a rate conversion system for matching a compressed video signal to a communications channel in 
accordance with a first illustrative embodiment of the present invention. 

Fig. 5 shows an illustrative video encoder having motion compensation coding which may be used in the environ- 
25 ment of Fig. 1 . 

Fig. 6 shows an illustrative video decoder having motion compensation decoding which may be used in the envi- 
ronment of Fig. 1 . 

Fig. 7 shows a rate conversion system for matching a compressed video signal to a communications channel in 
accordance with a second illustrative embodiment of the present invention. 
30 Fig. 8 shows the effect of inserting video program segments such as commercials into a video program in accord- 

ance with an illustrative embodiment of the present invention. 

Fig. 9 shows a system for inserting video program segments into a video program in accordance with an illustrative 
embodiment of the present invention. 

35 Detailed Description 

As is well known in the art, a video signal can be compressed in one of two modes -- constant bit rate and variable 
bit rate. For constant bit rate compression, the output rate of the encoder over a fixed interval is a constant. This is 
accomplished by varying the quantizer step size used in the encoder, and providing both the encoder and decoder 

40 with channel buffers. These buffers are used to ensure that there is always data available for the channel and data 
available from the channel, respectively In addition, the degree of fullness of the encoder's channel buffer can be used 
as a control input for the encoder. If the buffer is filling up too quickly, the quantization step size may be increased, 
which results in a lower output rate from the quantizer If the buffer is emptying too quickly, the quantization step size 
may be decreased, thereby generating more bits. 

45 There are two channel constraints induced by this type of communications channel. First, the decoder buffer can 

never be permitted to underflow. This condition occurs when the decoder needs more data and there is nothing left in 
its input buffer. When this occurs, the decoder must wait until more data is arrives, which results in a freezing of the 
resultant output video image. The second constraint is that the decoder buffer must not be permitted to overflow. This 
occurs when data arrives from the channel, and the decoder buffer is full. Since there is no room left in the buffer, the 

so data is lost. This occurrence typically results in errors appearing in the resultant output video image. 

In variable bit rate systems, it is assumed that the transmission rate of the channel must be controlled by the 
encoder in order to prevent information from being discarded or excessively delayed in the network. In the context of 
Asynchronous Transfer Mode (ATM) networks, for example, one particular type of channel is known as a leaky bucket 
channel. (As is known to those skilled in the art, ATM is a particular protocol in the category of packet switched network 

55 protocols. Communication across an ATM network may occur in either a fixed bit rate or a variable bit rate mode.) In 
particular, a leaky bucket channel has a peak rate capacity, a sustainable rate capacity, and a burst time. The burst 
time specifies how long an encoder may transmit at the peak rate without causing loss or excessive delay, whereas 
the encoder may transmit at the sustainable rate indefinitely. 
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The variable bit rate approach limits the average rate at which an encoder can transmit, but allows an encoder to 
transmit at the peak rate for a limited period of time. If the desired transmission rate is higher than the leaky bucket 
constraint would allow, the encoder must reduce its output rate in a manner analogous to the constant bit rate case 
(e.g. by increasing the quantizer step size). A set of conditions that each of these approaches need to meet in order 

5 to ensure that a) buffer overflow does not occur, b) buffer underflow does not occur, and c) the channel constraints are 
met, is known by those skilled in the art and is described, for example, in A. R. Reibman and B. G. Haskell, "Constraints 
on Variable Bit-Rate Video for ATM Networks," IEEE Transactions on Circuits and Systems for Video Technology, vol. 
2, No. 4. pp. 361-372, December 1992. 

Fig. 1 shows an illustrative environment in which a compressed video signal may be matched to a communications 

io channel. An input video signal is provided to encoder 12 which is coded and stored in a compressed form on storage 
media 14. The coding may, for example, employ a compression factor which advantageously preserves the perceptual 
quality of the video signal. Then, in response to a specific customer request to transmit the coded video signal, channel 
matching subsystem 1 6 further compresses the video signal retrieved from storage media 1 4 (if necessary) to match 
the constraints (e.g., available bit rate) of the communications channel. Finally, decoder 18 receives the coded video 

15 signal from the channel and decodes it to produce an output video signal. 

Encoder 12 of Fig. 1 may be implemented, for example, by the encoder shown in Fig. 2. This encoder is illustratively 
an intraframe encoder which performs intraf rame coding only. As is well known to those skilled in the art, in intraframe 
coding, a given frame is coded independent of the content of other frames. In , tnterframe' , coding, on the other hand, 
the data to be coded is compared with the corresponding data from a previous frame, and differences between them 

20 are coded. 

Specifically, each frame of video is broken up into blocks of pixels (typically of size 8x8) and then transformed into 
the frequency domain by transform 20. Transform 20 illustratively uses a linear transform such as the well-known 
Discrete Cosine Transform (DCT). The input block may be represented by f(x,y) where x and /represent spatial indices 
for the pixels within the block. The output of the linear transform will be denoted herein as F(u,\) t which depicts the 
25 frequency domain representation of the input data block. Here u and v represent the spatial frequency indices of the 
block. 

The resulting frequency domain coefficients produced by transform 20 are then quantized by quantizer 22, in order 
to reduce the entropy of the coefficients by a quantization process. This step results in a loss of information, of course, 
but provides for a reduction of the data rate in the system. As discussed above, the quantization process may illustra- 
te tively use a quantization step size which is sufficiently small so as not to reduce the perceptual quality of the ultimately 
reconstructed (Le., decoded) video. 

The quantization process performed by quantizer 22 may be defined, for example, as a division of each transform 
coefficient by a corresponding quantization step size value. This value advantageously may be the product of two 
terms, MQUANT and Q\J AWT (uy), in order to provide simultaneously for independent control of the quantization of 
35 individual coefficients and for convenient control of the overall quantization level (i.e., scaling of the overall output bit 
rate). In particular, QUANTfu,v^ may be selected based on perceptual criteria in order to maximize the quality of -the 
encoded image given the attendant reduction in bit rate. For example, QUANTfu,v;may be selected so that if MQUANT 
has a value of unity a reconstruction of the encoded video signal would be perceptually indistinguishable from the 
original video signal. Procedures for finding such a quantization matrix are well known to those of ordinary skill in the 
40 art. (See, e.g., H. Peterson, A. Ahumada and A. Watson, "An Improved Detection Model for DCT Coefficient Quanti- 
zation," Proc. of the International Society for Optical Engineering, vol. 1913, pp. 191-201, February 1993.) 

The value assigned to MQUANT may advantageously be used to adjust the overall output bit rate. Note, for ex- 
ample, that increasing MQUANT reduces the output bit rate since it increases the quantizer step size, thereby reducing 
the entropy of the quantizer output. Correspondingly, decreasing MQUANT increases the output bit rate by reducing 
45 the quantizer step size, which in turn increases the entropy of the quantized data. In the above-mentioned MPEG 
compression standards, for example, MQUANT can take on values in the rage of 1 to 31 . Thus, the matrix of quantized 
frequency domain coefficients, denoted herein as F Q (u,v), may be computed by quantizer 22 as 

cn F Q (u,v) = Integer Round (F(u,v) I (MQUANT * QUANTA v )) 

where the "Integer Round" functbn computes the closest integer to the value of its operand. 

In the encoder of Fig. 2, MQUANT is generated by rate control 28. Specifically, rate control 28 determines MQUANT 
based on the degree of fullness of channel input buffer 26, as described above. That is, rate control 28 monitors the 
55 state of channel input buffer 26 and adjusts MQUANT to ensure the buffer does not overflow or underflow and that the 
channel constraints are met. Many approaches for performing this operation are known to those skilled in the art. 
Typically, they operate by taking as input the degree of buffer fullness, the current value of MQUANT, statistics about 
the input data, and the channel constraints. Based on these inputs, they attempt to determine an optimal value of 
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MQUANT to be used for the quantization of the next data block. This approximated optimal value is commonly defined 
as the value that produces the highest quality output image while meeting the channel constraints. Examples of such 
techniques are described, for example, in Reibman and Haskell {see citation above) and in K. Ramchandran, A. Ortega 
and M. Vetterli. 'Bit Allocation for Dependent Quantization with Applications to Multiresolution and MPEG Video Coders, 

5 ' IEEE Transactions on Image Processing, vol. 3, no. 5, September 1994. 

In addition, rate control 28 may determine MQUANT based on information provided directly by the communications 
channel itself. (See, e.g., H. Kanakia, P. Mishra and A. Reibman, "An Adaplive Congestion Control Scheme for Real- 
Time Packet Video Transport." Proc. of ACM SIGCOMM, September 1993.) In the illustrative encoder shown in Fig. 
2, for example, both the degree of fullness of channel input buffer 26 and a signal provided directly from the commu- 

io nications channel are available. In other illustrative embodiments, either one or the other of these mechanisms may 
be used alone. 

Entropy coder 24 takes the fixed length quantized transform coefficients and produces a set of variable length 
channel symbols. This process introduces no further information loss, but minimizes the bit rate by coding more com- 
monly occurring values with fewer bits. Specifically, entropy coder 24 produces a compressed data stream whose rate 

is approaches the entropy of the quantized transform coefficients. Typical entropy coding techniques, familiar to those 
of ordinary skill in the art, include Huffman and Arithmetic coding. 

Finally, the variable length symbols generated by entropy coder 24 are inserted into channel input buffer 26 either 
for transmission across the communications cnannel, or, as in the environment of Fig. 1, for storage in storage media 
14 so as to be available for subsequent use. The various types of coded data that are put into channel input buffer 26 

20 include (a) bitstream synchronization information such as "start" and "marker" codes, (b) control information such as 
image size : frame rate, coding modes and quantizer scales (e.g., the value of MQUANT), and (c) the variable length 
coded (i.e., entropy coded) quantized transform coefficients themselves. Note that for a constant rate channel, for 
example, the same number ol bits are removed from the buffer and transmitted over the channel for each video frame 
(i.e., over the time period represented by each video frame). 

25 Fig. 3 shows a decoder which corresponds to the encoder of Fig. 2 and may illustratively be used to implement 

decoder 16 of Fig. 1. In operation, data which is received from the communications channel is placed into channel 
output buffer 30. For a constant rate channel, for example, the same number of bits arrive and are placed into channel 
output buffer 30 for each video frame (i.e., over the time period represented by each video frame). This data is removed 
from channel output buffer 30 as it is required by the decoder and the synchronization information and the control 

30 information are extracted therefrom by control information decoder 32. Note that the value of MQUANT in particular is 
extracted as part of the control information. 

The variable length coded quantized transform coefficients are applied to entropy decoder 34 which produces a 
quantized symbol stream. These quantized symbols are then converted back into a matrix of transform coefficients by 
inverse quantizer 36. This matrix, rel erred to herein as F Q (u,v), is computed by performing a multiplication by MQUANT 

35 and QUANT(u,v; as follows: 

F Q (u,v ) = F Q (u,v) * QUANT(u,v) * MQUANT 

40 Finally, the transform coefficients are converted back into the spatial domain by inverse transform 38, which per- 

forms the inverse operation to that of transform 20 of the encoder of Fig. 2. The resultant output images (for the individual 
frames) may then be displayed at the times specified by the synchronization information which was extracted by control 
information decoder 32. The resultant overall video is preferably as perceptually indistinguishable as possible from the 
original video signal. 

45 As described above, channel matching subsystem 16 of the environment of Fig. 1 may be implemented by (a) 

processing the input bitstream with the decoder of Fig. 3 to generate a decoded video signal, and (b) providing the 
resultant decoded video signal to the encoder of Fig. 2 which re-encodes the data for the new channel conditions. 
Alternatively, channel matching subsystem 16 may be implemented by the rate conversion system of Fig. 4 in accord- 
ance with a first illustrative embodiment of the present invention. In particular, the system of Fig. 4 enables a compressed 

50 video signal to be matched to a communications channel with a system of reduced complexity to that of prior art 
techniques. 

The rate conversion system of Fig. 4 operates as follows. First, the input bitstream is read into channel output 
buffer 30. The control and synchronization information is then extracted by control information decoder 32. Next, the 
variable length coded transform coefficients are decoded by entropy decoder 34. Then, the re-quantization process is 
55 advantageously carried out as a single process by rate change module 40. Moreover, note that this process is performed 
without converting the transform coefficients back into the spatial domain (i.e., to pixel data), as is done, for example, 
by inverse transform 38 of the decoder of Fig. 3 (or, for that matter, transforming the resultant spatial domain data back 
again into the frequency domain, as is done, for example, by transform 20 of the encoder of Fig. 2). 
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Specifically, the matrix of transform coefficients, F Q (u,v), is computed by rate change module 40 as follows: 

f q(u>v) = FQ(u,v) * (OLD_MQUANT/NEW_MQUANT) 

where OLD.MQUANT is the value of MQUANT previously used to encode the stored bitstream (i.e., the MQUANT 
value extracted by control information decoder 32), and NEW_MQUANT is determined by rate control 28 to ensure 
that the new channel constraints are met. As in the case of the encoder of Fig. 2, rate control 28 generates the desired 
quantization level (in this case, NEW_MQUANT) based on the degree of fullness of channel input buffer 26 and/or a 
signal received from the communications channel. 

Finally, entropy coder 24 takes the fixed length quantized transform coefficients generated by rate change module 
40 and produces a new set of variable length channel symbols. These symbols are inserted into channel input buffer 
26 (along with the synchronization information and the control information) for transmission across the communications 
channel. In this manner, the compressed video signal has been re-encoded with a different quantization level so as to 
meet the constraints of the given communications channel. Moreover, this has been achieved with a system having 
reduced complexity over that of prior art techniques. 

The above-described system for matching a compressed video signal to a communications channel in accordance 
with an illustrative embodiment of the present invention can be extended to the case where the compressed video 
signal has been coded with the use of motion compensation. As is well known to those skilled in the art, motion com- 
pensation is a technique used in interframe video coding to further reduce the bit rate required to transmit a coded 
signal. Interframe coding techniques typically operate by generating a prediction for blocks of the current frame from 
blocks of the previously encoded frame. Then, only the. difference between the frame being coded and the generated 
prediction needs to be coded and transmitted. Since the previously encoded frame (as opposed to the actual previous 
frame) is advantageously used for this prediction, errors do not propagate over time. 

With motion compensation, the prediction is generated by determining the location of the block from the previously 
encoded frame which provides the best estimate of the block to be coded. Specifically, the location of this chosen block 
from the previously encoded frame is encoded though the use of motion vectors. A motion vector specifies the relative 
location of the prediction block with respect to the current block to be coded. Thus, the encoding of the current block 
comprises only a motion vector and difference (between the block being coded and the prediction block from the 
previously encoded frame) information. 

Fig. 5 shows an illustrative video encoder having motion compensated interframe coding which may be used in 
the environment of Fig. 1 . The block of the frame which is to be coded is subtracted from the prediction block by 
subtractor 52 to generate the difference. This difference signal is now transformed into the frequency domain and 
quantized by transform 20 and quantizer 22, respectively, using the techniques described above in the discussion of 
the illustrative encoder of Fig. 2. Finally, both the quantized information and the motion vectors used to generate the 
prediction are entropy coded by entropy coder 24 and inserted into channel input buffer 26 (along with the synchroni- 
zation information and the control information) for transmission across the communications channel or for storage, as 
described above. 

In order to generate the prediction block, the illustrative encoder of Fig. 5 includes a subsystem which mimics the 
behavior of a corresponding decoder in the following manner. First, the quantized transform coefficients are inverse 
quantized and inverse transformed by inverse quantizer 36 and inverse transform 38, respectively, in order to generate 
a reconstructed version of the quantized difference signal. This signal is then added by adder 54 to the prediction block 
from the previous frame and stored in frame buffer 56. Frame buffer 56 then uses the motion vectors for the given 
block (as determined by motion estimator 58) to retrieve the appropriate data to use as the prediction block (La, to 
supply to subtractor 52). Specifically, motion estimator 58 evaluates a plurality of possibly motion vectors, and selects 
one of these based on quality of the corresponding prediction. 

Fig. 6 shows an illustrative video decoder having motion compensated interframe coding which corresponds to 
the illustrative encoder of Fig. 5. As in the illustrative decoder of Fig. 3, data which is received from the communications 
channel is placed into channel output buffer 30. This data is removed from channel output buffer 30 as it is required 
by the decoder, and the synchronization and control information are extracted therefrom by control information decoder 
32. Note again that the value of MQUANT in particular is extracted as part of the control information. 

The variable length coded quantized transform coefficients and motion vectors are applied to entropy decoder 34 
which produces a quantized symbol stream and the motion vectors. The quantized symbols are converted back into 
a matrix of ( un-quantized) transform coefficients by inverse quantizer 38. Then, the transform coefficients are converted 
back into the spatial domain by inverse transform 38. Note, however, that in the illustrative decoder of Fig. 6 (unlike 
the decoder of Fig. 3), this spatial domain data represents difference information as opposed to actual pixel data. 

The motion vectors are applied to frame buffer 56 (which contains the previously decoded frame) for use in gen- 
erating a prediction block. The prediction block is then added to the difference data by adder 54 to produce the pixel 
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data of the given block of the current frame for use in the output video signal. Note that the output video signal data is 
also stored back in frame bufler 56 for use in generating the prediction blocks for the next frame. 

In an analogous manner to that described above in connection with the illustrative embodiment of Fig. 4, channel 
matching subsystem 16 of the environment of Fig. 1 may be implemented by (a) processing the input bitstream with 

5 the decoder of Fig. 6 to generate a decoded video signal, and (b) providing the resultant decoded video signal to the 
encoder of Fig. 5, which re-encodes the data for the new channel conditions. Alternatively, however, channel matching 
subsystem 16 may be implemented by the illustrative rate conversion system of Fig. 7 in accordance with a second 
illustrative embodiment of the present invention. In particular, the system of Fig. 7 enables a compressed video signal 
having been coded with motion compensated interframe coding to be matched to a communications channel with a 

10 system of reduced complexity to that of prior art techniques. 

One difference between performing rate conversion in the case where the compressed video signal employs motion 
compensated interframe coding and in the case employing intraf rame coding only as described above results because 
the quantized difference signal for the current frame depends on the previously encoded frame. The previously encoded 
frame, in turn, depends on the encoded frame previous to it and the quantized difference signal from the previous 

*5 frame. Thus, if the quantized difference signal changes, as it does during the re-quantization process, there is the 
potential for errors to accumulate over time. In order to avoid such problems, the additional error introduced by the re- 
quantization process for a given frame must be computed, saved, and added back in to the quantized difference signal 
for the next frame. 

Thus, the illustrative rate conversion system of Fig, 7 operates as follows. As in the case of the illustrative system 

20 of Fig. 4, the input bitstream is first read into channel output buffer 30. The synchronization information and the control 
information are then extracted by control information decoder 32. Next, the variable length coded transform coefficients 
and motion vectors are decoded by entropy decoder 34 to produce quantized symbols and motion vectors, respectively. 
Then, inverse quantizer 36 converts the quantized symbols back into a matrix of transform coefficients (representing 
differences). Specifically, the inverse quantization comprises multiplication by OLD_MQUANT to produce the recon- 

25 structed frequency domain difference signal. Before this difference signal is re-quantized to the desired quantization 
level, however, the propagated error which is due to the re-quantization process performed on the previous frame is 
advantageously added to this difference signal by adder 70, in order to avoid the accumulation of the re-quantization 
error as described above. The result of this addition, therefore, is an error-corrected frequency domain difference signal. 
The error-corrected frequency domain difference signal may now be re-quantized by quantizer 22 based on the 

30 value of NEW_MQUANT, which has been determined by rate control 28. Specifically, the re-quantization performed 
by quantizer 22 comprises division by NEW_MQUANT. Finally, the rate converted (Le., re-quantized) information, along 
with the motion vectors which were entropy decoded by entropy decoder 34, are (re-)entropy coded by entropy coder 
24 and inserted into channel input buffer 26 (along with the synchronization and control information) for transmission 
across the communications channel. As in the illustrative system of Fig. 4 : the degree of fullness of channel input buffer 

35 26, and/or a signal provided directly from the communications channel, may be used as inputs to rate control module 
28 to determine the appropriate value for NEWJvlQUANT. 

To determine the propagated error which is due to the re-quantization process performed on the previous frame, 
the rate converted (i.e., re-quantized) result from quantizer 22 is first inverse quantized by (Le., multiplied by) 
NEW_MQUANT. This operation is performed by inverse quantizer 72. In this manner, a reconstructed (i.e., inverse 

40 quantized) rate converted difference signal is produced. Then, the output of inverse quantizer 36, which comprises a 
reconstructed non-rate converted difference signal, is subtracted from the output of inverse quantizer 72 to determine 
the amount of error which resulted from the re-quantization (i.e., rate conversion) process. 

This determined error, which, advantageously, is still represented in the frequency domain, is now stored in error 
frame buffer 76. In order to generate the propagated error due to rate conversion, however, the frequency domain 

45 information in frame buffer 76 must be motion compensated - that is, it must be translated by the applicable motion 
vector values. A conventional approach to achieving such a result would be to apply an inverse transform before frame 
buffer 76, perform conventional motion compensation in the spatial domain, and then apply a (forward) transform after 
the motion compensation. However, it is known to those skilled in the art that various operations on video images, 
including motion compensation, advantageously may be performed directly on data in the transform (i.e., frequency) 

50 domain. See, e.g., B. C. Smith and L. FHowe, "Algorithms for Manipulating Compressed Images,' IEEE Computer 
Graphics and Applications, pp. 34-42, September 1993, and S-F. Chang and D. E. Messerschmidt, "Manipulation and 
Compositing of MC-DCT Compressed Video," IEEE Journal on Selected Areas in Communications, vol. 1 3, No. 1. pp. 
1-11, January 1995. In light of this knowledge, and based on the motion vectors provided by entropy decoder 34, 
frequency domain motion compensation 78 advantageously performs such an operation directly on the data stored in 

55 error frame buffer 76. The result is the propagated error signal due to rate conversion. 

As in the case of the first illustrative embodiment (i.e., the system of Fig. 4), note that the entire rate conversion 
process of the system of Fig. 7 is performed without converting the transform coefficients back into the spatial domain 
(as is done, for example, by inverse transform 38 of the decoder of Fig. 6) or transforming spatial domain data (such 
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as the difference data) into the frequency domain (as is done, for example, by transform 20 of the encoder of Fig. 5). 
In this manner, the compressed video signal is re-encoded with a different quantization level meeting the constraints 
of the given communications channel, with use of a technique having reduced complexity over that of the prior art 
techniques. 

5 In accordance with one illustrative embodiment of the present invention, video program segments may be inserted 

into another video program. The video program segments may, for example, be downstream commercials. Such an 
application may be useful when a compressed program is distributed from one location to a plurality of other locations 
via potentially multiple distribution channels. At some point in the distribution path of one or more of these channels, 
it may be desired to replace a portion of the distributed program with a different video program segment. For example, 

io local television stations and cable companies often insert local commercials into network program feeds. The effect of 
such a process is illustratively shown in Fig. 8. As can be seen in this figure, a portion of original program 82 -- namely, 
that portion between time T START and time T END is to be replaced by the data contained in inserted program segment 
84. 

If an insertion process such as that depicted in Fig. 8 is to be followed by a transmission of the resultant video 
*s across a communications channel, channel and buffer constraints such as those described above will need to be met. 
In order to ensure such conditions, the bit rate used tor the inserted program segment should advantageously be 
adjusted based on the boundary conditions set by the original program. 

Fig. 9 shows a system for inserting video program segments such as commercials into a video program in accord- 
ance with an illustrative embodiment of the present invention. Rate conversion module 70 may, for example, be the 
20 illustrative system of Fig. 7. For the time previous to T START , input selector 90 is in a first position, thereby providing 
original program B2 as the output program after appropriate rate conversion is performed by rate conversion module 
70. Between time T START and time T END , input selector 90 is in a second position, thereby providing inserted program 
segment 84 as the output program after appropriate rate conversion is performed by rate conversion module 70. At 
time T END , input selector is returned to the first position, thereby again providing original program 82 as the output 
25 program after appropriate rate conversion is performed by rate conversion module 70. In this manner, a compressed 
video program segment such as a commercial may be inserted into another compressed video program, and the bit 
rates of both programs may be matched to a communications channel with use of a system having reduced complexity 
over that of prior art techniques. 

For clarity of explanation, the illustrative embodiment of the present invention has been presented as comprising 
30 individual functional blocks. The functions these blocks represent may be provided through the use of either shared 
or dedicated hardware, including, but not limited to, hardware capable of executing software. The functions of the 
processing blocks presented in the instant figures may, for example, be provided by a single shared processor. (Use 
of the term "processor" should not be construed to refer exclusively to hardware capable of executing software.) Illus- 
trative embodiments may comprise digital signal processor (DSP) hardware, such as the AT&T DSP16 or DSP32C, 
35 read-only memory (ROM) for storing software performing the operations discussed herein, and random access memory 
(RAM) for storing DSP results. Very large scale integration (VLSI) hardware embodiments, as well as custom VLSI 
circuitry in combination with a general purpose DSP circuit, may also be provided. 

Although a number of specific embodiments of this invention have been shown and described herein, it is to be 
understood that these embodiments are merely illustrative of the many possible specific arrangements which can be 
devised in application of the principles of the invention. Numerous and varied other arrangements can be devised in 
accordance with these principles by those of ordinary skill in the art without departing from the scope of the-Jnvention. 
For example, although the illustrative embodiments described above have in each case involved compressed video 
signals, the principles of the instant invention may be applied as well to compressed speech, audio, or image signals, 
or, for that matter, any other signal comprising data which has been compressed with use of a quantization process. 
In addition, although the illustrative embodiments shown above have been described in the context of an ATM network, 
the principles of the instant invention may be applied as well to any communications channel having a potentially limited 
available bandwidth. 



so Claims 

1 . A method of re-coding a first encoded signal to generate a second encoded signal which meets a bit rate constraint 
of a communications channel, the first encoded signal and the second encoded signal each representing a common 
original signal, the first encoded signal comprising quantized frequency domain data, the quantized frequency 
domain data having been quantized to a first quantization level, the method comprising the steps of: 



40 



45 



ss 



re-quantizing the quantized frequency domain data to a second quantization level different than the first quan- 
tization level without transforming the quantized frequency domain data out of the frequency domain, the 
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second quantization level based on the bit rate constraint of the communications channel; and 

generating the second encoded signal based on the re-quantized frequency domain data. 

s 2. The method of claim 1 wherein the quantized frequency domain data has been entropy coded, the method further 
comprising the steps of: 

entropy decoding the quantized frequency domain data prior to the re-quantizing step; and 

w entropy coding the re-quantized frequency domain data. 

3. The method of claim 1 wherein the quantized frequency domain data has been generated by transforming non- 
frequency domain data into the frequency domain with use of a frequency domain transform. 

is 4. The method of claim 3 wherein the common original signal represents video information and the non-frequency 
domain data comprises pixel data. 

5. The method of claim 4 wherein the frequency domain transform comprises a discrete cosine transform. 

20 6. The method of claim 3 wherein the common original signal represents video information and the non-frequency 
domain data comprises motbn<:ompensated interframe difference data. 

7. The method of claim 6 wherein the frequency domain transform comprises a discrete cosine transform. 

25 8. The method of claim 3 wherein the common original signal represents audio information and the non-frequency 
domain data comprises signal amplitude data. 

9. The method of claim 1 comprising the further step of determining the bit rate constraint of the communications 
channel based on a measure of fullness of a channel input buffer coupled to the communications channel. 

30 

10. The method of claim 1 comprising the further step of determining the bit rate constraint of the communications 
channel based on a signal received from the communications channel. 

11. The method of claim 1 wherein the communications channel comprises a channel of a packet switched network. 

35 

1 2. The method of claim 1 1 wherein the packet switched network comprises a network having an Asynchronous Trans- 
fer Mode protocol. 

13. The method of claim 1 wherein the first encoded signal further comprises encoded control information, the method 
40 further comprising the step of decoding the encoded control information, and wherein the step of generating the 

second encoded signal comprises generating the second encoded signal further based on the decoded control 
information. 

14. The method of claim 1 comprising the further step of replacing a portion of a third encoded signal which meets the 
45 bit rate constraint of the communications channel with the second encoded signal. 

.15. The method of claim 14 wherein the common original signal and the third encoded signal each represent video 
information and wherein the video information represented by the common original signal comprises a television 
commercial. 

so 

16. A method for communicating an original signal across a communications channel having a bit rate constraint 
associated therewith, the method comprising the steps of: 

encoding the original signal to generate a first encoded signal comprising encoded control information and 
55 quantized frequency domain data, the quantized frequency domain data quantized to a first quantization level; 



decoding the encoded control information; 
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re-quantizing the quantized frequency domain data to a second quantization level different than the first quan- 
tization level without transforming the quantized frequency domain data out of the frequency domain, the 
second quantization level based on the bit rate constraint associated with the communications channel; 

5 generating a second encoded signal based on the encoded control information and the re-quantized frequency 

domain data; and 

transmitting the second encoded signal across the communicatbns channel to a destination. 

10 17. The method of claim 16 further comprising the step of storing the first encoded signal in a storage device., and 
wherein the step of re-quantizing the quantized frequency domain data comprises retrieving the quantized fre- 
quency domain data from the storage device. 

18. The method of claim 1 6 further comprising the steps of: 

15 

receiving the second encoded signal at the destination; and 

decoding the second encoded signal at the destination to produce an output signal representing the original 
signal. 

20 

19. The method of claim 18 further comprising the step of storing the first encoded signal in a storage device and 
wherein the step of re-quantizing the quantized frequency domain data comprises retrieving the quantized fre- 
quency domain data from the storage device. 

2S 20. An apparatus for re-coding a first encoded signal to generate a second encoded signal which meets a bit rate 
constraint of a communications channel, the first encoded signal and the second encoded signal each representing 
a common original signal, the first encoded signal comprising quantized frequency domain data, the quantized 
frequency domain data having been quantized to a first quantization level, the apparatus comprising: 

30 a quantizer adapted to re-quantize the quantized frequency domain data toa second quantization level different 

than the first quantization level without transforming the quantized frequency domain data out of the frequency 
domain, the second quantizatbn level based on the bit rate constraint of the communications channel; and 

a signal generator of the second encoded signal based on the re -quantized frequency domain data. 

35 

• 21. The apparatus of claim 20 wherein the quantized frequency domain data has been entropy coded, the apparatus 
further comprising: 

an entropy decoder adapted to be applied to the quantized frequency domain data; and 

40 

an entropy coder adapted to be applied to the re-quantized frequency domain data. 

22. The apparatus of claim 20 wherein the quantized frequency domain data has been generated by transforming 
non-frequency domain data into the frequency domain with use of a frequency domain transform. 

45 

23. The apparatus of claim 22 wherein the common original signal represents video information and the non-frequency 
domain data comprises pixel data. 

24. The apparatus of claim 23 wherein the frequency domain transform comprises a discrete cosine transform. 

so 

25. The apparatus of claim 22 wherein the common original signal represents video information and the non-frequency 
domain data comprises motion -compensated interframe difference data. 

26. The apparatus of claim 25 wherein the frequency domain transform comprises a discrete cosine transform. 

ss 

27. The apparatus of claim 22 wherein the common original signal represents audio information and the non-frequency 
domain data comprises signal amplitude data. 
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28. The apparatus of claim 20 further comprising: 

a channel input buffer coupled to the communications channel; and 

a rate control module adapted to determine the bit rate constraint of the communications channel based on a 
measure of fullness of the channel input buffer. 

29. The apparatus of claim 20 further comprising a rate control module adapted to determine the bit rate constraint of 
the communications channel based on a signal received from the communications channel. 

30. The apparatus of claim 20 wherein the communications channel comprises a channel of a packet switched network. 

31. The apparatus of claim 30 wherein the packet switched network comprises a network having an Asynchronous 
Transfer Mode protocol. 

32. The apparatus of claim 20 wherein the first encoded signal further comprises encoded control information, the 
apparatus further comprising a decoder adapted to be applied to the encoded control information, and wherein 
the signal generator of the second encoded signal is adapted to generate the second encoded signal based on 
both the re-quantized frequency domain data and the decoded control information. 

33. The apparatus of claim 20 further comprising a switch adapted to replace a portion of a third encoded signal with 
the second encoded signal, wherein the third encoded signal also meets the bit rate constraint of the communi- 
cations channel. 

34. The apparatus of claim 33 wherein the common original signal and the third encoded signal each represent video 
information and wherein the video information represented by the common original signal comprises a television 
commercial. 

35. A communications system for communicating an original signal across a communications channel having a bit 
rate constraint associated therewith, the system comprising: 

an encoder adapted to be applied to the original signal and adapted to generate a first encoded signal com- 
prising encoded control information and quantized frequency domain data, the quantized frequency domain 
data quantized to a first quantization level; 

a decoder adapted to be applied to the encoded control information; 

a quantizer adapted to re-quantize the quantized frequency domain data toa second quantization level different 
than the first quantization level without transforming the quantized frequency domain data out of the frequency 
domain, the second quantization level based on the bit rate constraint associated with the communications 
channel; 

a signal generator of a second encoded signal based on both the encoded control information and the re- 
quantized frequency domain data; and 

a transmitter coupled to the communications channel, the transmitter adapted to transmit the second encoded 
signal across the communications channel to a destination. 

36. The communications system of claim 35 further comprising a storage device adapted to store the first encoded 
signal, and wherein the quantizer is further adapted to retrieve the quantized frequency domain data from the 
storage device. 

37. The communications system of claim 35 further comprising: 

a receiver coupled to the communications channel at the destination, the receiver adapted to receive the 
second encoded signal; and 

a decoder adapted to decode the second encoded signal at the destination and to produce an output signal 
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representing the original signal. 

The communications system of claim 37 further comprising a storage device adapted to store the first encoded 
signal, and wherein the quantizer is further adapted to retrieve the quantized frequency domain data from the 
storage device. 
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